import Vue from 'vue'
import Router from 'vue-router'

// @ts-ignore
const Login = () => import('@/pages/Login')

Vue.use(Router)

// 解决ElementUI导航栏中的vue-router在3.0版本以上重复点菜单报错问题
const originalPush = Router.prototype.push
Router.prototype.push = function push (location) {
  return originalPush.call(this, location).catch(err => err)
}

const routerList = [];

/**
 * 动态引入路由
 * @param r
 */
function importALl (r) {
  r.keys().forEach(
    (key) => routerList.push(r(key).default)
  );
}

// @ts-ignore
importALl(require.context('./routes/', false, /\.routers.js/));

export default new Router({
  mode: 'history', /** 路由模式 为 hash 与 history  */
  /* 两者的优缺点页比较明显: hash 路由有利于兼容老的浏览器 ,history 更有利于 SEO优化,样式更为好看一点 */
  routes: [
    ...routerList,
    {
      path: '/login',
      name: 'Login',
      component: Login
    }
  ]
});
